<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>CSS Animations: parsing animation-name with valid values</title>
<link rel="help" href="https://drafts.csswg.org/css-animations/#propdef-animation-name">
<meta name="assert" content="animation-name supports the full grammar '[ none | <keyframes-name> ]#'.">
<script src="../../../resources/testharness.js"></script>
<script src="../../../resources/testharnessreport.js"></script>
<script src="../../../css/support/parsing-testcommon.js"></script>
</head>
<body>
<script>
test_valid_value("animation-name", 'none');
test_valid_value("animation-name", 'NONE', 'none');

test_valid_value("animation-name", 'foo');
test_valid_value("animation-name", 'Both');
test_valid_value("animation-name", 'ease-in');
test_valid_value("animation-name", 'infinite');
test_valid_value("animation-name", 'paused');
test_valid_value("animation-name", 'first, second, third');

test_valid_value("animation-name", '"something"', 'something');
test_valid_value("animation-name", '"---\\22---"', '---\\\"---');
test_valid_value("animation-name", '"multi word string"', 'multi\\ word\\ string');

// Restricted keywords as strings
test_valid_value("animation-name", '"none"');
test_valid_value("animation-name", '"none", "INITIAL", "inherit"');
test_valid_value("animation-name", '"none", both, ease-in');
test_valid_value("animation-name", '"NoNe"');
test_valid_value("animation-name", '"initial"');
test_valid_value("animation-name", '"INITIAL"');
test_valid_value("animation-name", '"inherit"');
test_valid_value("animation-name", '"INHERIT"');
test_valid_value("animation-name", '"revert"');
test_valid_value("animation-name", '"REVERT"');
test_valid_value("animation-name", '"revert-layer"');
test_valid_value("animation-name", '"REVERT-LAYER"');
test_valid_value("animation-name", '"unset"');
test_valid_value("animation-name", '"UNSET"');
test_valid_value("animation-name", '"default"');
test_valid_value("animation-name", '"DEFAULT"');
</script>
</body>
</html>
